Navigation tool

ABSTRACT

This invention relates to a navigation tool for connecting to a display device, comprising at least two sensor elements having known positions relative to each other, each sensor element being coupled to detector means for recording a change in a predetermined parametre and timing means for determining the time of change at each sensor element and calculating means for calculating the direction and speed of the recorded changes based on the relative positions of the sensor elements and the duration between the recorded changes.

[0001] This invention relates generally to a navigation tool for connecting to a display device, and more specifically to motion detection based on signals typically from a finger scanner and related equipment.

[0002] The market of biometrics is evolving rapidly, and the industry is becomming more mainstreamed. However, for biometrics to penetrate the consumer market, requirements are strict in respect to both price and performance (eg. power consumption).

[0003] Currently finger scanners are typically pure capturing devices, hence the responsibility of any signal processing is left to the host. Thus, for implementation in eg. a mobile phone, requirements are also strict in respect to the use of processing power and memory of the signal processing. Nevertheless, as these processes mature and can be implemented in the finger scanner device, the requirements will still apply.

[0004] The size of a matrix finger scanner is typically restricted by the size of the finger images to be captured, due to the number of interconnects if the sensor where to be separated from the IC. Since the price is typically very much proportional to the size of the silicon die, the price of matrix finger scanner can not be expected to decrease significantly. For a stripe finger scanner, however, where the user wipes a finger over one or more arrays of sensor elements, the number of channels is reduced dramatically and separation of sensor and IC is possible, and the size of the IC is not restricted to the size of finger images. The reduction in channels of course also contributes to reduce the size of the die substantially. Since the price and the size of the IC are so related, stripe finger scanners have the potential of breaking the consumer market.

[0005] International patent application no. PCT/NO98/00182 describes a stripe fingerscanner requiring that the finger is moved over the scanner, which then samples information about the finger surface and generates a twodimensional representation of the finger image.

[0006] For stripe finger scanners, the user must be allowed to pull the finger over the scanner at various velocity. If the finger scanner samples at a fixed rate, this causes for a method that detects the speed of a finger and remaps the rows that are sampled, so that the axes of the remaped finger image are equal and linear.

[0007] Menu controlled electronic equipment, such as PDA's or some mobilephones, require some type of control device coupled to the display to enable to user to choose from the menus. This may be performed using pointer tools such as touch sensitive displays, navigation wheels or touch sensitive pads, also adding to the equipment costs. It is an object of this invention to provide a navigation tool based on a fingerprint sensor technology, the sensor thus is obtaining an additional functionality without adding hardware or complicated software to the product.

[0008] In some cases, especially related to small units such as mobile phones, the menues on the displays are simplified, thus only requiring navigation in a limited number of direction, e.g. up, down, right and left.

[0009] This object is obtained using a navigation tool as described above, being characterized in that it comprises at least two sensor elements having known positions relative to each other, each sensor element being coupled to detector means for recording a change in a predetermined parametre and timing means for determining the time of change at each sensor element and calculating means for calulating the direction and speed of the recorded changes based on the relative positions of the sensor elements and the duration between the recorded changes.

[0010] The invention will be described below with reference to the accompanying drawings, illustrating the invention by way of examples.

[0011]FIG. 1 illustrates schematically a linear fingerprint sensor.

[0012]FIG. 2 illustrates a first method for velocity measurements.

[0013]FIG. 3 further illustrates the method in FIG. 2.

[0014]FIG. 4 illustrates an alternative method for measuring velocity.

[0015]FIG. 5 illustrates a semi linear fingerprint sensor adapted for use as a pointer tool.

[0016]FIG. 6 illustrates the procedure for using the layout illustrated in FIG. 5 for detecting movements in two dimensions.

[0017]FIG. 7 illustrates an alternativ layout for a finger print sensor being usable as a pointer tool.

[0018]FIG. 8 illustrates an additional alternative layout for a finger print detector pointer tool.

[0019]FIG. 9 illustrates an additional alternative layout for a finger print detector pointer tool.

[0020]FIG. 10 illustrates a four directional navigation tool.

[0021] The typical method for determining the speed of a finger pulled over a stripe finger scanner would be to use auto correlation. This would require one or more additional arrays of sensor elements parallel to the image sensor elements, if the image sensor elements consists of only one array.

[0022] Important factors for a speed correction process to run on eg. a mobile phone, are that it should be fast, require litle processing power and use litle memory. Preferrably it should run in real-time, due to the amount of memory that would be required to buffer a finger image captured of fingers wiped at various velocities, if the speed correction is post-processed.

[0023] Some facts about eg. a finger pulled over a finger scanner, can be used to simplify and create a more efficient process for determening the velocity of the finger. FIG. 1 shows a possible layout of sensor elements for such a solution corresponding to the solution described in the abovementioned international patent application PCT/NO98/00182. The layout consists of one array of image sensor elements, and one array of additional speed correction sensor elements. Each additional speed correction sensor element form a pair with a corresponding sensor element in the image sensor element array, as indicated. Since the direction a finger is pulled is known, such a pair can be used to detect the speed of a finger. For enhanced tolerance on the finger pulling direction, adjacent sensor elements on the image array can be used.

[0024] The sensors may of course be active continuously, thus measuring any changes close to the sensors at any time, but for use in mobile phones or PDA's a preferable additional features is that at least one touch sensitive sensor is provided which may activate the others automatically. Thus saving the power resources of the equipment. This touch activation may be based on any type of sensor, but is preferably based on the use of at least one of the scanner sensors, e.g. triggering the measurements at a predetermined change in the capacitance of the sensor sorroundings. Examples of producing such means are descusssed in international application . . . (claiming priority from Norwegian applications No 2000.3004 and 2000.3003).

[0025] An example of a digital readout according to the invention of a speed correction channel pair is shown in FIG. 2. Calibration of any significant variation in offset and gain between the channels should be performed prior to speed correction. The two time series represents the same section of a finger, since the sensor elements are in line with the pulling direction of the finger, where the phase angle between the two signals represents the time the finger uses from the front channel to the back. However, due to variations in velocity of the finger, the sections may be distortet in the time scale.

[0026] The range of velocity a user may pull a finger should be set in accordance with what is natural for a human being. When a finger is pulled at a natural speed, the velocity will not vary significantly within one cycle of the signal, ie. one ridge of the finger surface. Because of this, it is possible to only make a few measurements during one cycle and let these values be valid for a fixed time-frame as indicated in the figure. To get the most exact phase angle, measurements should be done on the flanks of the signal, ie. where the signal is increasing or decreasing rapidly.

[0027] As shown in FIG. 3, a sample in the front channel can be selected based on the signal level variation of the two adjecent samples. The pitch of the two sensor elements in a speed correction pair should be less than the smallest pitch expected of the ridges in a finger surface. Thus, whenever the signal in the back channel crosses the level of a sample selected in the front channel, it represents the same point on the finger surface. The calculation of the measurement should be at subpixel level for increased accuracy. When the number of samples is known for one point at the surface of the finger to move from the front channel to the back, the speed of the finger can then be expressed as: v = D * F/n where v is the speed D is the pitch of the two sensor elements F is the sampling frequency of one channel n is the number of samples

[0028] The distance the finger has moved during one sampling cycle of a channel, can be express as: d = v / F where d is the distance the finger has moved during one sampling cycle of a channel

[0029] From the two equations we get:

d=D/n

[0030] Since the pitch of the sensor elements of a pair is fixed, the distance the finger has moved during one sampling cycle of a channel, is inversely proportional to the number of samples one point on the surface of the finger uses to move from the front channel to the back. By accumulating the delta distances the finger moves from sample to sample of the same channel, selections can be made of which rows to discard, and wich rows to map to the finger image maintain the correct scale, or new values can be calculated from interpolation.

[0031] As shown in FIG. 1 a certain number of speed correction pairs should be spread out along the image array. This would be to minimise the possibility that the ridges are parallel to the direction the finger is pulled for all the pairs, wich would cause the process to fail to detect any speeds. For those pairs that detects speeds, the results for the different pairs should be averadged for enhanced accuracy. If for some period no speeds are valid, history should be used.

[0032] For the solution described so far, the requirement to the signal quality is relatively strict in respect to signal/noise ratio. For finger scanners that don't provide this signal quality, a similar approach can be used, to the cost of some increase in processing power and memory usage.

[0033]FIG. 4 shows a sketch of such an approach. Line T₁ marks the peak point of a valley of a finger section from a back channel. When a successive sample exceeds a certain threshold T₂ from the peak point, that valley will be defined. The area A below the previous ridge is now ready to be defined. This can be done by setting a level T_(A) eg. ¾ from the peak point of the ridge to the closer of the peak points of the two alongside valleys. Since the last defined valley does not yet have two ridges alongside, it is not ready to be fully defined until the next ridge is defined. To complete the definition of the ridge, the area A can be used to compute the vertical axis of gravity G₁. Line G₂ represents the axis of gravity of the correlating ridge in the front speed channel, as the figure is showing the back channel. The number of samples between G₁ and G₂ represents the same phase angle as in the approach described above, and hence can be replaced in that description.

[0034] Since a finger scanner will not be active for much time in eg. a mobile phone or Personal Digital Assistant (PDA), the value would be increased substantially if such a unit would include some kind of pointer functionality. The combination of two such modes in one unit is favorable since the modes are exclusively active. Since the mobile phone technology is moving towards graphical displays (opposed to character based displays), with displays growing bigger and number of buttons being reduced, the need for a pointer device is becoming more important. For PDAs this is already the case. Typical pointing devices for mobile phones and PDAs today are navigation keys or pen. The touchpads typically used in portable computers are too large to be convenient for such devices as mobile phones and PDAs.

[0035] This invention describes a method for adding the functionality of a pointer into a finger scanner by utilising the structure of the finger. While a touchpad detects a finger being moved over its surface, this method detects the movement of the sensor area over the finger surface. For a stripe finger scanner this requires som additional sensor elements, while for matrix finger scanners a selection of the already existing sensor elements is sufficient. As this mode will be active for a substantial amount of time during the use of a mobile phone or PDA, it is of importance that the number of sensor elements being used is reduced to a minimum, to keep the consumption of power, processor and memory of the host low.

[0036] The method for measuring velocity according to this invention may easily be used to detect the direction of the finger, e.g. by using two perpendicular fingerprint scanners and as suggested above comparing the signals from the speed correection sensor not only with the signals from the closest sensor in the array but also with the sensors being close to this, and thus providing a possibility for calculating the angle of the movement.

[0037] An example of a layout of the sensor elements for this method is shown in FIG. 5. The principle of the pointer function is to determine the direction of the finger being moved and then calculate the distance on the basis of the speed of the finger.

[0038] When the finger is being moved over the scanner each of the four arrays of elements shown in FIG. 5, two vertical and two horisontal, will scan a section of the finger. The measured values of each sensor element is stored in an array representing the history if each element, the length of said stored history depending on the possible velocities of the moving surface. Each array is then compared to the latest history of the other array on the same axis, to search for an identical section but allowing a displacement of 45. When a match is found the direction is determined and on the basis of the displacement and the axis of the match. In more detail this is performed as follows:

[0039] The most current samples from the sensor elements in the left vertical array are subtracted from the most current samples of the uppermost sensor elements in the right vertical array. The sum of the absolute values of these 12 subtractions is stored as an element in a matrix. The same procedure is performed on the left array, with different subsections on the right array moving one sensor element downwards for each time. In this example this will be performed eight times, and the results will be represented as one column in a matrix. This is repeated for a chosen number of times by subtracting the most current samples of the left array from the historic samples of the right array, thus generating a matrix as follows: $\left\lfloor \begin{matrix} {{\sum\limits_{m = 1}^{12}{{a_{m} - b_{m,1}}}}\quad} & {\sum\limits_{m = 1}^{12}{{a_{m} - b_{m,2}}}} & \cdots \\ {\sum\limits_{m = 1}^{12}{{a_{m} - b_{{m + 1},1}}}} & {\sum\limits_{m = 1}^{12}{{a_{m} - b_{{m + 1},2}}}} & \cdots \\ \cdots & \cdots & \cdots \\ {\sum\limits_{m = 1}^{12}{{a_{m} - b_{{m + 8},1}}}} & {\sum\limits_{m = 1}^{12}{{a_{m} - b_{{m + 8},2}}}} & \cdots \end{matrix} \right\rfloor\quad$

[0040] where a_(i) is the most current sample from element i in the left array and b_(j,k) is sample from element j in the right array where k represents the historic number and k=1 is the most current. The number of rows in the matrix represents the resolution of angle, while the number of columns represents the range and resolution in time of the velocity of a finger. The number of columns and will also set the requirement for buffering of samples.

[0041] One more matrix is created where the samples of the most current right array is compared with the history of the left array. Additionally, two simular matrixes are created from the vertical arrays. The global minimum of these four matrixes will represent the current speed and direction of the finger, as shown in FIG. 6. This complete procedure is repeated at a certain rate to detect changes in the motion.

[0042] When the speed and direction is initially established, the procedure can zoom in on a smaller range depending on the expected variations and sampling rate.

[0043] For enhanced accuracy, time frames of the pixel rows can be used instead of just single rows. The pitch between sensor elements and between the arrays of sensor elements should be optimised for the expected pitch of ridges and valleys in a finger surface, eg. 50 and 200 μm respectively (which results in a sensor area of less than 1 mm²).

[0044] Increased accuracy of speed and direction can be obtained by interpolation of the global minimum. The maximum velocity of a finger is related to the sampling rate. A threshold should be set for the global minimum to detect if the speed is within the operating range. Some sensor elements should be used for finger on/off detection—by eg. requireing a certain number of these elements to be above a certain threshold—to prevent processing when a finger is off, both in respect to processing power and the fact that all values in the matrixes will be almost zero in that case.

[0045] This finger on/off detection can also be used to detect taps and double taps by counting the number of samples the finger is on or off (if the sampling rate is fixed), and setting limits for how long the finger is allowed to be on/off. Tap detection can also be replaced by pressure sensing, eg. by checking changes in time of the total signal level of all sensor elements. FIG. 7, FIG. 8 and FIG. 9 shows alternative layouts of the sensor elements, which requires some more or less changes to the procedure.

[0046] For mobile phones with character based displays, the need for a pointer is restricted to a navigator that enables the user to browse menus. This is currently typically solved by the use of keys or a roller drum. Implementation of such a mode for finger scanners, can be done with much less requirements to power consumption, processing power and memory usage.

[0047] This embodiment of invention describes a method for a four directional navigation, based on four, or more, additional sensor elements on a stripe finger scanner. The sensor elements should be larger than the image sensor elements, because the structure of the finger surface is regarded as noise in this context. For matrix finger scanners, clusters of image sensor elements can be used to represent a large element.

[0048]FIG. 10 shows an example of a layout of such sensor elements. The purpose of the navigation sensor elements is purely to detect the presence of a finger or not, which simply can be solved by a signal level threshold. If a finger is wiped over the sensor area, the four navigation sensor elements will be triggered at certain points in time.

[0049] The direction of the finger wipe is given by the two first elements that are triggered, ie. if N1 and N2 are triggered first, the direction is down; if N1 and N3 are triggered first, the direction is right; if N2 and N4 are triggered first, the direction is left; and if N3 and N4 are triggered first, the direction is up. Additionally a check can be done on the difference. in time between the first and the second and the first and the third element are triggered. If these time differences are almost equal, the wipe can be disregarded because the finger has been wiped close to a borderline between two of the four directions.

[0050] The setting of a threshold for an acceptable factor between these two differences, represents the tolerance of the angle a user may wipe the finger in a direction. Furthermore, if a threshold is set for a minimum of the time difference between the first and the third sensor elements are triggered, the process kan distinguish between wipes in a direction and a tap. Timing of the presence and absence of a finger enables detection of single and double taps. Also, a scrolling feature can be implemented in such a way, that if a finger is wiped onto the sensor area and detected as a valid direction, and the finger is kept on the sensor area, after a certain time the procedure can interprate this as repetetive wipes in the same direction, and at a certain rate.

[0051] A number of variations over this concept are of course possible, such as allowing for more precise relative measurements indicating the speed, using a larger number og sensors for detecting a larger number of directions or even using only two sensors for detecting movements along only one axis.

[0052] The principle of the navigation in general may be summarized in the follonwing steps:

[0053] A) A finger is detected at a certain channel, e.g. by the signal level rising above a certain limit. The time is stored related to the incident.

[0054] B) When the time for the signal passing the threshold is stored for a certain number of sensors the determination of the direction of the movement may start.

[0055] C) The stored times for each pair of sensor elements is compared to find the first, thus indicating the direction of movement.

[0056] D) An approximate speed of the finger is found on the basis of the number of samples, and thus the known time between the samples, between the threshold passes at each sensor.

[0057] In addition the calulated speed may be compared with a predetermined acceptable range of speeds and directions to determine if the calculated signals are within an acceptable and possible range. The acceptable directions may be limited by the use of the navigation tool, e.g. by the positioned and choices to be made a the PDA or mobile phone display.

[0058] The number of sensor elements can be increased or decreased to adapt for more or less directions, ie. two sensor elements can detect two directions, while 8 sensor elements can detect 8 directions.

[0059] This invention is described as primarily based on a finger print scanner of the type described in International patent application no. PCT/NO98/00182 thus primarily on capacitance measurements on a finger surface. It is, however, clear that the invention may used different sensor types, such as thermal sensors, within the scope of this invention. 

1. Navigation tool for connecting to a display device, characterized in that it comprises at least two sensor elements having known positions relative to each other, each sensor element being coupled to detector means for recording a change in a predetermined parametre and timing means for determining the time of change at each sensor element and calculating means for calulating the direction and speed of the recorded changes based on the relative positions of the sensor elements and the duration between the recorded changes.
 2. Navigation tool according to claim 1, wherein the recorded time is related to the exceeding of a predetermined threshold at a sensor element.
 3. Navigation tool according to claim 1, also comprising a display device coupled to the calculating means for indicating the measured movements on the display.
 4. Navigation tool according to claim 1, wherein the parametres measured by the sensor elements are sampled at chosen intervals, the measured values being compared to chosen thresholds, and the recorded times being equivalent with the sample number at the recording.
 5. Navigation tool according to claim 1, wherein duration of the exceeding of the threshold is recorded.
 6. Navigation tool according to claim 1, wherein the sensors are related to a finger scanner, being adapted to measure chosen parametres of a finger surface in the vicinity of the sensor.
 7. Navigation tool according to claim 6, wherein the measure parametre is the capacitance of the finger close to the sensor.
 8. Navigation tool according to claim 1, wherein the calculated direction and velocity is compared to a range of acceptable values. 